home *** CD-ROM | disk | FTP | other *** search
/ Atari Mega Archive 1 / Atari Mega Archive - Volume 1.iso / gnu / sed / sed113.zoo / utils.c < prev   
C/C++ Source or Header  |  1992-10-16  |  5KB  |  309 lines

  1. /*  Functions from hack's utils library.
  2.     Copyright (C) 1989, 1990, 1991 Free Software Foundation, Inc.
  3.  
  4.     This program is free software; you can redistribute it and/or modify
  5.     it under the terms of the GNU General Public License as published by
  6.     the Free Software Foundation; either version 2, or (at your option)
  7.     any later version.
  8.  
  9.     This program is distributed in the hope that it will be useful,
  10.     but WITHOUT ANY WARRANTY; without even the implied warranty of
  11.     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12.     GNU General Public License for more details.
  13.  
  14.     You should have received a copy of the GNU General Public License
  15.     along with this program; if not, write to the Free Software
  16.     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
  17.  
  18. /* These routines were written as part of a library (by hack), but since most
  19.    people don't have the library, here they are.  */
  20.  
  21. #ifdef __STDC__
  22. #define VOID void
  23. #else
  24. #define VOID char
  25. #endif
  26.  
  27. #include <stdio.h>
  28. #if defined(USG) || defined(STDC_HEADERS)
  29. #include <string.h>
  30. #else
  31. #include <strings.h>
  32. #endif
  33. #if defined(STDC_HEADERS)
  34. #include <stdlib.h>
  35. #else
  36. VOID *malloc();
  37. VOID *realloc();
  38. #endif
  39.  
  40. VOID *ck_malloc();
  41.  
  42. char *myname;
  43.  
  44. #ifdef __STDC__
  45. #include <stdarg.h>
  46.  
  47. /* Print an error message and exit */
  48. void
  49. panic(char *str, ...)
  50. {
  51.     va_list iggy;
  52.  
  53.     fprintf(stderr,"%s: ",myname);
  54.     va_start(iggy,str);
  55. #ifdef HAVE_VPRINTF
  56.     vfprintf(stderr,str,iggy);
  57. #else
  58. #ifdef HAVE_DOPRNT
  59.     _doprnt(str,&iggy,stderr);
  60. #endif
  61. #endif
  62.     va_end(iggy);
  63.     putc('\n',stderr);
  64.     exit(4);
  65. }
  66.  
  67. #else
  68. #include <varargs.h>
  69.  
  70. void
  71. panic(str,va_alist)
  72. char *str;
  73. va_dcl
  74. {
  75.     va_list iggy;
  76.  
  77.     fprintf(stderr,"%s: ",myname);
  78.     va_start(iggy);
  79. #ifdef HAVE_VPRINTF
  80.     vfprintf(stderr,str,iggy);
  81. #else
  82. #ifdef HAVE_DOPRNT
  83.     _doprnt(str,&iggy,stderr);
  84. #endif
  85. #endif
  86.     va_end(iggy);
  87.     putc('\n',stderr);
  88.     exit(4);
  89. }
  90.  
  91. #endif
  92.  
  93. /* Store information about files opened with ck_fopen
  94.    so that error messages from ck_fread, etc can print the
  95.    name of the file that had the error */
  96. #define N_FILE 32
  97.  
  98. struct id {
  99.     FILE *fp;
  100.     char *name;
  101. };
  102.  
  103. static struct id __id_s[N_FILE];
  104.  
  105. /* Internal routine to get a filename from __id_s */
  106. char *
  107. __fp_name(fp)
  108. FILE *fp;
  109. {
  110.     int n;
  111.  
  112.     for(n=0;n<N_FILE;n++) {
  113.         if(__id_s[n].fp==fp)
  114.             return __id_s[n].name;
  115.     }
  116.     return "{Unknown file pointer}";
  117. }
  118.  
  119. /* Panic on failing fopen */
  120. FILE *
  121. ck_fopen(name,mode)
  122. char *name;
  123. char *mode;
  124. {
  125.     FILE    *ret;
  126.     int    n;
  127.  
  128.     ret=fopen(name,mode);
  129.     if(ret==(FILE *)0)
  130.         panic("Couldn't open file %s",name);
  131.     for(n=0;n<N_FILE;n++) {
  132.         if(ret==__id_s[n].fp) {
  133.             free((VOID *)__id_s[n].name);
  134.             __id_s[n].name=(char *)ck_malloc(strlen(name)+1);
  135.             strcpy(__id_s[n].name,name);
  136.             break;
  137.         }
  138.     }
  139.     if(n==N_FILE) {
  140.         for(n=0;n<N_FILE;n++)
  141.             if(__id_s[n].fp==(FILE *)0)
  142.                 break;
  143.         if(n==N_FILE)
  144.             panic("Internal error: too many files open");
  145.         __id_s[n].fp=ret;
  146.         __id_s[n].name=(char *)ck_malloc(strlen(name)+1);
  147.         strcpy(__id_s[n].name,name);
  148.     }
  149.     return ret;
  150. }
  151.  
  152. /* Panic on failing fwrite */
  153. void
  154. ck_fwrite(ptr,size,nmemb,stream)
  155. char *ptr;
  156. int size,nmemb;
  157. FILE *stream;
  158. {
  159.     if(fwrite(ptr,size,nmemb,stream)!=nmemb)
  160.         panic("couldn't write %d items to %s",nmemb,__fp_name(stream));
  161. }
  162.  
  163. /* Panic on failing fclose */
  164. void
  165. ck_fclose(stream)
  166. FILE *stream;
  167. {
  168.     if(fclose(stream)==EOF)
  169.         panic("Couldn't close %s",__fp_name(stream));
  170. }
  171.  
  172. /* Panic on failing malloc */
  173. VOID *
  174. ck_malloc(size)
  175. int size;
  176. {
  177.     VOID *ret;
  178.  
  179.     if(!size)
  180.         size++;
  181.     ret=malloc(size);
  182.     if(ret==(VOID *)0)
  183.         panic("Couldn't allocate memory");
  184.     return ret;
  185. }
  186.  
  187. /* Panic on failing realloc */
  188. VOID *
  189. ck_realloc(ptr,size)
  190. VOID *ptr;
  191. int size;
  192. {
  193.     VOID *ret;
  194.  
  195.     ret=realloc(ptr,size);
  196.     if(ret==(VOID *)0)
  197.         panic("Couldn't re-allocate memory");
  198.     return ret;
  199. }
  200.  
  201. /* Return a malloc()'d copy of a string */
  202. char *
  203. ck_strdup(str)
  204. char *str;
  205. {
  206.     char *ret;
  207.  
  208.     ret=(char *)ck_malloc(strlen(str)+2);
  209.     strcpy(ret,str);
  210.     return ret;
  211. }
  212.  
  213.  
  214. /* Implement a variable sized buffer of 'stuff'.  We don't know what it is,
  215.    nor do we care, as long as it doesn't mind being aligned by malloc. */
  216.  
  217. struct buffer {
  218.     int    allocated;
  219.     int    length;
  220.     char    *b;
  221. };
  222.  
  223. #define MIN_ALLOCATE 50
  224.  
  225. VOID *
  226. init_buffer()
  227. {
  228.     struct buffer *b;
  229.  
  230.     b=(struct buffer *)ck_malloc(sizeof(struct buffer));
  231.     b->allocated=MIN_ALLOCATE;
  232.     b->b=(char *)ck_malloc(MIN_ALLOCATE);
  233.     b->length=0;
  234.     return (VOID *)b;
  235. }
  236.  
  237. void
  238. flush_buffer(bb)
  239. VOID *bb;
  240. {
  241.     struct buffer *b;
  242.  
  243.     b=(struct buffer *)bb;
  244.     free(b->b);
  245.     b->b=0;
  246.     b->allocated=0;
  247.     b->length=0;
  248.     free(b);
  249. }
  250.  
  251. int
  252. size_buffer(b)
  253. VOID *b;
  254. {
  255.     struct buffer *bb;
  256.  
  257.     bb=(struct buffer *)b;
  258.     return bb->length;
  259. }
  260.  
  261. void
  262. add_buffer(bb,p,n)
  263. VOID *bb;
  264. char *p;
  265. int n;
  266. {
  267.     struct buffer *b;
  268.     int x;
  269.     char * cp;
  270.  
  271.     b=(struct buffer *)bb;
  272.     if(b->length+n>b->allocated) {
  273.         b->allocated*=2;
  274.         b->b=(char *)ck_realloc(b->b,b->allocated);
  275.     }
  276.     
  277.     x = n;
  278.     cp = b->b + b->length;
  279.     while (x--)
  280.       *cp++ = *p++;
  281.     b->length+=n;
  282. }
  283.  
  284. void
  285. add1_buffer(bb,ch)
  286. VOID *bb;
  287. int ch;
  288. {
  289.     struct buffer *b;
  290.  
  291.     b=(struct buffer *)bb;
  292.     if(b->length+1>b->allocated) {
  293.         b->allocated*=2;
  294.         b->b=(char *)ck_realloc(b->b,b->allocated);
  295.     }
  296.     b->b[b->length]=ch;
  297.     b->length++;
  298. }
  299.  
  300. char *
  301. get_buffer(bb)
  302. VOID *bb;
  303. {
  304.     struct buffer *b;
  305.  
  306.     b=(struct buffer *)bb;
  307.     return b->b;
  308. }
  309.